import Vue from 'vue'
import App from './App.vue'
// 三级联动组件---全局组件
import TypeNav from '@/components/TypeNav'
import Carsousel from '@/components/Carousel'
import Pagination from '@/components/Pagination'
import {
  Button,
  MessageBox,
  Message
} from 'element-ui';
import * as filters from '@/filters'
// 统一接口api文件夹里面全部请求函数
// 统一引入
import * as API from '@/api'

// 第一个参数：是你全局组件的名字 第二个参数 哪一个组件
Vue.component(TypeNav.name, TypeNav)
Vue.component(Carsousel.name, Carsousel)
Vue.component(Pagination.name, Pagination)
Vue.component(Button.name, Button);

// Element注册
Vue.prototype.$msgbox = MessageBox
Vue.prototype.$alert = MessageBox.alert
Vue.prototype.$message = Message;
// 引入MockServer.js---mock数据
import '@/mock/mockServer'
// 引入swiper样式
import 'swiper/css/swiper.css'
// 引入路由
import router from '@/router'
// 引入仓库
import store from '@/store'

// 全局管道符
Vue.filter("tofixed", (val) => {
  return val.toFixed(2)
})

Object.keys(filters).forEach(key => {
  Vue.filter(key, filters[key])
})

Vue.config.productionTip = false
import atm from '@/assets/1.gif'
// 引入插件
import VueLazyload from 'vue-lazyload'
// 注册插件
Vue.use(VueLazyload, {
  // 懒加载默认的图片
  loading: atm
})


// 引入自定义插件
import myPlugins from './plugins/myPlugins'
Vue.use(myPlugins, {
  name: "upper"
})

// 引入表单校验插件
import '@/plugins/validate'

new Vue({
  render: h => h(App),
  // 全局事件总线 $bus的配置
  beforeCreate() {
    Vue.prototype.$bus = this;
    Vue.prototype.$API = API;
  },
  // 注册路由: 底下的写法KV一致省略V【router小写的】
  // 注册路由信息 当这里书写router的时候 组件身上都拥有$route,$router属性
  router,
  // 注册仓库：组件实例的身上会多一个属性$store属性   
  store
}).$mount('#app')